# 10.0 ADDRESSABLE UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (USART) The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules. (USART is also known as a Serial Communications Interface or SCI.) The USART can be configured as a full-duplex asynchronous system that can communicate with peripheral devices, such as CRT terminals and personal computers, or it can be configured as a half-duplex synchronous system that can communicate with peripheral devices, such as A/D or D/A integrated circuits, serial EEPROMs, etc. The USART can be configured in the following modes: - · Asynchronous (full-duplex) - · Synchronous Master (half-duplex) - Synchronous Slave (half-duplex) Bit SPEN (RCSTA<7>) and bits TRISC<7:6> have to be set in order to configure pins RC6/TX/CK and RC7/RX/DT as the Universal Synchronous Asynchronous Receiver Transmitter. The USART module also has a multi-processor communication capability using 9-bit address detection. ### REGISTER 10-1: TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS 98h) | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R-1 | R/W-0 | |-------|-------|-------|-------|-----|-------|------|-------| | CSRC | TX9 | TXEN | SYNC | | BRGH | TRMT | TX9D | | it 7 | | *** | | | | | bit 0 | bit 7 CSRC: Clock Source Select bit Asynchronous mode: Don't care. Synchronous mode: - 1 = Master mode (clock generated internally from BRG) - 0 = Slave mode (clock from external source) - bit 6 TX9: 9-bit Transmit Enable bit - 1 = Selects 9-bit transmission - 0 = Selects 8-bit transmission - bit 5 TXEN: Transmit Enable bit - 1 = Transmit enabled - 0 = Transmit disabled Note: SREN/CREN overrides TXEN in Sync mode. - bit 4 SYNC: USART Mode Select bit - 1 = Synchronous mode - 0 = Asynchronous mode - bit 3 Unimplemented: Read as '0' - bit 2 BRGH: High Baud Rate Select bit Asynchronous mode: - 1 = High speed - 0 = Low speed Synchronous mode: Unused in this mode. - bit 1 TRMT: Transmit Shift Register Status bit - 1 = TSR empty - 0 = TSR full - bit 0 TX9D: 9th bit of Transmit Data, can be Parity bit | 1000 | | | | |------|---|---|---| | Leg | _ | - | _ | | 1 60 | | | " | | | | | | R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown # REGISTER 10-2: RCSTA: RECEIVE STATUS AND CONTROL REGISTER (ADDRESS 18h) | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0 | R-0 | R-x | |-------|-------|-------|-------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | it 7 | | | | | | Annual Control of the | hit ( | bit 7 SPEN: Serial Port Enable bit 1 = Serial port enabled (configures RC7/RX/DT and RC6/TX/CK pins as serial port pins) 0 = Serial port disabled bit 6 RX9: 9-bit Receive Enable bit 1 = Selects 9-bit reception 0 = Selects 8-bit reception bit 5 SREN: Single Receive Enable bit Asynchronous mode: Don't care. Synchronous mode - Master: 1 = Enables single receive 0 = Disables single receive This bit is cleared after reception is complete. Synchronous mode - Slave: Don't care. bit 4 CREN: Continuous Receive Enable bit Asynchronous mode: 1 = Enables continuous receive 0 = Disables continuous receive Synchronous mode: 1 = Enables continuous receive until enable bit CREN is cleared (CREN overrides SREN) 0 = Disables continuous receive bit 3 ADDEN: Address Detect Enable bit Asynchronous mode 9-bit (RX9 = 1): 1 = Enables address detection, enables interrupt and load of the receive buffer when RSR<8> is set 0 = Disables address detection, all bytes are received and ninth bit can be used as parity bit bit 2 FERR: Framing Error bit 1 = Framing error (can be updated by reading RCREG register and receive next valid byte) 0 = No framing error bit 1 OERR: Overrun Error bit 1 = Overrun error (can be cleared by clearing bit CREN) 0 = No overrun error bit 0 RX9D: 9th bit of Received Data (can be parity bit but must be calculated by user firmware) Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown # 10.1 USART Baud Rate Generator (BRG) The BRG supports both the Asynchronous and Synchronous modes of the USART. It is a dedicated 8-bit baud rate generator. The SPBRG register controls the period of a free running 8-bit timer. In Asynchronous mode, bit BRGH (TXSTA<2>) also controls the baud rate. In Synchronous mode, bit BRGH is ignored. Table 10-1 shows the formula for computation of the baud rate for different USART modes which only apply in Master mode (internal clock). Given the desired baud rate and Fosc, the nearest integer value for the SPBRG register can be calculated using the formula in Table 10-1. From this, the error in baud rate can be determined. It may be advantageous to use the high baud rate (BRGH = 1) even for slower baud clocks. This is because the Fosc/(16 (X + 1)) equation can reduce the baud rate error in some cases. Writing a new value to the SPBRG register causes the BRG timer to be reset (or cleared). This ensures the BRG does not wait for a timer overflow before outputting the new baud rate. #### 10.1.1 SAMPLING The data on the RC7/RX/DT pin is sampled three times by a majority detect circuit to determine if a high or a low level is present at the RX pin. TABLE 10-1: BAUD RATE FORMULA | SYNC | BRGH = 0 (Low Speed) | BRGH = 1 (High Speed) | |------|----------------------------------------------|-------------------------------| | 0 | (Asynchronous) Baud Rate = Fosc/(64 (X + 1)) | Baud Rate = Fosc/(16 (X + 1)) | | 1 | (Synchronous) Baud Rate = Fosc/(4 (X + 1)) | N/A | **Legend:** X = value in SPBRG (0 to 255) # TABLE 10-2: REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | E AMONDO CONTRACTOR | e on:<br>BOR | all o | e on<br>ther<br>sets | |---------|-------|---------|------------------------------|-------|-------|--------|-------|-------|-------|---------------------|--------------|-------|----------------------| | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | 100 To | BRGH | TRMT | TX9D | 0000 | -010 | 0000 | -010 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | 0000 | 000x | 0000 | 000x | | 99h | SPBRG | Baud Ra | Baud Rate Generator Register | | | | | | | 0000 | 0000 | 0000 | 0000 | Legend: x = unknown, - = unimplemented, read as '0'. Shaded cells are not used by the BRG. TABLE 10-3: BAUD RATES FOR ASYNCHRONOUS MODE (BRGH = 0) | D | | | osc = 20 MHz | | osc = 16 M | lHz | Fosc = 10 MHz | | | |-------------|---------|------------|-----------------------------|---------|------------|-----------------------------|---------------|------------|-----------------------------| | RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | 0.3 | - | - | - | - | - | - | - | - | - | | 1.2 | 1.221 | 1.75 | 255 | 1.202 | 0.17 | 207 | 1.202 | 0.17 | 129 | | 2.4 | 2.404 | 0.17 | 129 | 2.404 | 0.17 | 103 | 2.404 | 0.17 | 64 | | 9.6 | 9.766 | 1.73 | 31 | 9.615 | 0.16 | 25 | 9.766 | 1.73 | 15 | | 19.2 | 19.531 | 1.72 | 15 | 19.231 | 0.16 | 12 | 19.531 | 1.72 | 7 | | 28.8 | 31.250 | 8.51 | 9 | 27.778 | 3.55 | 8 | 31.250 | 8.51 | 4 | | 33.6 | 34.722 | 3.34 | 8 | 35.714 | 6.29 | 6 | 31.250 | 6.99 | 4 | | 57.6 | 62.500 | 8.51 | 4 | 62.500 | 8.51 | 3 | 52.083 | 9.58 | 2 | | HIGH | 1.221 | - | 255 | 0.977 | - | 255 | 0.610 | - | 255 | | LOW | 312.500 | - | 0 | 250.000 | 12 | 0 | 156.250 | - | 0 | | | | Fosc = 4 M | Hz | Fosc = 3.6864 MHz | | | | |---------------------|--------|------------|-----------------------------|-------------------|------------|-----------------------------|--| | BAUD<br>RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | | 0.3 | 0.300 | 0 | 207 | 0.3 | 0 | 191 | | | 1.2 | 1.202 | 0.17 | 51 | 1.2 | 0 | 47 | | | 2.4 | 2.404 | 0.17 | 25 | 2.4 | 0 | 23 | | | 9.6 | 8.929 | 6.99 | 6 | 9.6 | 0 | 5 | | | 19.2 | 20.833 | 8.51 | 2 | 19.2 | 0 | 2 | | | 28.8 | 31.250 | 8.51 | 1 | 28.8 | 0 | 1 | | | 33.6 | - | 121 | - | - | - | - | | | 57.6 | 62.500 | 8.51 | 0 | 57.6 | 0 | 0 | | | HIGH | 0.244 | - | 255 | 0.225 | - | 255 | | | LOW | 62.500 | 4 | 0 | 57.6 | | 0 | | # TABLE 10-4: BAUD RATES FOR ASYNCHRONOUS MODE (BRGH = 1) | ADLL | . 10-4. | DAGD | IVAILO | OITAG | HOINK | 0110001 | HODE (DICOIT = 1) | | | | |-------------|----------|---------------|-----------------------------|----------|---------------|-----------------------------|-------------------|---------------|-----------------------------|--| | DALID | F | Fosc = 20 MHz | | | Fosc = 16 MHz | | | Fosc = 10 MHz | | | | RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | | 0.3 | - | ĕ | - | - | - | - | - | - | - | | | 1.2 | - | - | - | - | - | | - | - | 1 - L - | | | 2.4 | - | - | 11/2 | - | - | _ | 2.441 | 1.71 | 255 | | | 9.6 | 9.615 | 0.16 | 129 | 9.615 | 0.16 | 103 | 9.615 | 0.16 | 64 | | | 19.2 | 19.231 | 0.16 | 64 | 19.231 | 0.16 | 51 | 19.531 | 1.72 | 31 | | | 28.8 | 29.070 | 0.94 | 42 | 29.412 | 2.13 | 33 | 28.409 | 1.36 | 21 | | | 33.6 | 33.784 | 0.55 | 36 | 33.333 | 0.79 | 29 | 32.895 | 2.10 | 18 | | | 57.6 | 59.524 | 3.34 | 20 | 58.824 | 2.13 | 16 | 56.818 | 1.36 | 10 | | | HIGH | 4.883 | - | 255 | 3.906 | | 255 | 2.441 | - | 255 | | | LOW | 1250.000 | - | 0 | 1000.000 | | 0 | 625.000 | 101 | 0 | | | DAUD | F | osc = 4 Mi | łz | Fosc = 3.6864 MHz | | | | |---------------------|---------|----------------|-----------------------------|-------------------|------------|-----------------------------|--| | BAUD<br>RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | | 0.3 | - | - | - | - | - | - | | | 1.2 | 1.202 | 0.17 | 207 | 1.2 | 0 | 191 | | | 2.4 | 2.404 | 0.17 | 103 | 2.4 | 0 | 95 | | | 9.6 | 9.615 | 0.16 | 25 | 9.6 | 0 | 23 | | | 19.2 | 19.231 | 0.16 | 12 | 19.2 | 0 | 11 | | | 28.8 | 27.798 | 3.55 | 8 | 28.8 | 0 | 7 | | | 33.6 | 35.714 | 6.29 | 6 | 32.9 | 2.04 | 6 | | | 57.6 | 62.500 | 8.51 | 3 | 57.6 | 0 | 3 | | | HIGH | 0.977 | - | 255 | 0.9 | = | 255 | | | LOW | 250.000 | 1 <del>-</del> | 0 | 230.4 | 20 | 0 | |